home *** CD-ROM | disk | FTP | other *** search
/ Amiga Format CD 42 / Amiga Format AFCD42 (Issue 126, Aug 1999).iso / -serious- / programming / c / pmm / pmmanager.lha / PMM / Doku / DemoConfig / Projekt < prev    next >
Encoding:
Text File  |  1999-03-08  |  8.0 KB  |  186 lines

  1. ; Diese Datei stellt ein Projekt dar. Hier wird auf die
  2. ; Programm-Dateien verwiesen, alle Pfade werden hier
  3. ; gesetzt. * gilt immer, außer ein Programm übersteuert.
  4. ; $1, $2 ... $9 (Variablen für pmm.cfg)
  5. ; $$.c=  Pfad für Source, wenn nicht identisch mit PFAD=
  6. ;
  7. ; Wichtig:
  8. ; Hier angegebene Include-Pfade sind nur für den Compiler
  9. ; und nicht für den Depend-Scan. Der Scan hat seine Include-
  10. ; pfade in der Pmm.UsrIncludes. Aufbau: Pro Zeile ein Include.
  11. ; Der Compiler sucht natürlich auch in in den Standard-Compiler-
  12. ; includes während der Depend-Scan ALLE Pfade mit den eigenen Dateien
  13. ; enthält. Bei Bedarf kommt vielleicht include/libraries mit da rein.
  14. ; Aber jedes Compiler-.h-File zu prüfen ist Unsinn. Nach einem Compiler-
  15. ; update sollte man ohnehin alles einheitlich neu übersetzen.
  16. ; Es ist für den Dependscan nicht nötig programmabhängig zu verwalten.
  17. ; Die Config dient mehr dem Ausschluß von Pfaden, nur wäre das wesent-
  18. ; lich mehr Arbeit. Der Homepfad der Sourcen ist für Depend immer ent-
  19. ; halten. Beim Compilieren wird der Pfad gebraucht, weil er an den
  20. ; Preprozessor übergeben werden muß. Pmm könnte das zwar auch alleine
  21. ; einsetzen, aber das würde die Möglichkeiten beschränken. Also immer
  22. ; -I$I als Include übergeben.
  23. ;
  24. ; Die Zeilen mit MAKE am Anfang:
  25. ; Hier bekommen die Zahlencodes 1%, 2% usw. ihre Zuordnung.
  26. ; MAKE=5 bedeutet: Make ohne Zusatz stellt Definition 5 her (ist als
  27. ;                  68040 vordefiniert).
  28. ; MAKE:xyz=1,2,3   Besagt nichts weiter als das Pmm ... -o xyz die
  29. ;                  Definitionen 1, 2 und 3 erstellen soll, so wie
  30. ;                  bei Make xyz im Makefile 'xyz:' als Festlegung für
  31. ;                  Aufrufparameter steht.
  32. ; MAKE:ALL=....    Das ist die Festlegung, welche Definitionen bei
  33. ;                  Pmm A, Q, I oder Pmm -o ALL erzeugt werden.
  34. ; Diese Einstellungen sind eine Erweiterung zu Pmm.Cfg, aber es geht
  35. ; weiter...
  36. ;
  37. ; Source und sonstige Files:
  38. ; $&.c ist source.c     Preprozessor Input  ( .c -> vcpp )
  39. ; $&.i ist soirce.i     Preprozessor Output ( .c -> vcpp -> .i )
  40. ; $&.a ist source.asm   Compiler Output     ( .i -> vbcc -> .asm )
  41. ; $&.s ist source.s     Compiler Output     ( .i -> vbcc -> .s (vsc) -> .asm )
  42. ; $&.o ist source.o     Assembler Output    ( .asm -> Assembler -> .o [ -> Linker] )
  43. ; $$   ist PROGRAMM     Letzter Output (Programm, Library, Lib etc.)
  44. ; vsc ist der Scheduler, siehe Docs für Warp-Version!!!
  45. ; Dies alles geschieht automatisch. Für .i, .a, .s und .o werden nur noch die
  46. ; Pfade festgelegt. Bei $$ der Name des Programmes INCL. Pfad, wenn gewünscht.
  47. ; Falls nicht, wird a.out imaktuellen Verzeichnis benutzt. Siehe $$ unten...
  48. ; $L Ergänzung der .Lib/.a-Dateien für den Linker.
  49. ;
  50. ; Warum dieser Eintrag, ginge doch genauso gut in Pmm.Cfg?
  51. ; WEIL Pmm.Cfg nur Dinge enthalten sollte die allgemein gültig sind.
  52. ; Diese Projektdatei wird künftig mehrfach angelegt werden können, so
  53. ; das Projekte in Sub-Projekte unterteilt werden können, bzw. auch
  54. ; mehrere Projekte möglich werden. Dann sollte hier das stehen, was
  55. ; für das Projekt vom sonstigen Standard abweicht.
  56. ;
  57. :BEGIN *
  58. MAKE=5
  59. MAKE:60=5,6
  60. MAKE:PPC=7,8
  61. MAKE:ALL=1,2,3,4,5,6,7,8
  62. 1%$&.o=obj/000/
  63. 2%$&.o=obj/010/
  64. 3%$&.o=obj/020/
  65. 4%$&.o=obj/030/
  66. 5%$&.o=obj/040/
  67. 6%$&.o=obj/060/
  68. 7%$&.o=obj/ppc/
  69. 8%$&.o=obj/wos/
  70. $&.i=T:
  71. $&.a=T:
  72. $&.s=T:
  73. $$=a.out
  74. $L=Lib:DOSLIB_000.Lib Lib:All.Lib
  75. 5%$L=Lib:DOSLIB_040.Lib Lib:All_040.Lib
  76. 6%$L=Lib:DOSLIB_060.Lib Lib:All_040.Lib
  77. 7%$L=Lib:DOSLIB_ppc.a Lib:All_ppc.a
  78. 8%$L=Lib:DOSLIB_wos.a Lib:All_wos.Lib
  79. $o=T:LinkOBJ
  80. :END
  81. ;    <- Das END in der vorigen Zeile beendet die Config. AB hier kann
  82. ;       wieder ein BEGIN gesetzt werden. $o ist der Name für ein Temp-File
  83. ;       das die Lise der Objektfiles für den Linker enthält. Diese wird
  84. ;       von Pmm erstellt.
  85. ; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
  86. ;
  87. ; DEMO-EINTRAG -- KEINE FUNKTION --
  88. ; ----------------------------------
  89. ; DOSLIB ist ein SPECIAL, der Linker wird übersteuert mit L=PmmLibr!
  90. ;        Hier entsteht eine .LIB, gesteuert über den eigenen Libr-Befehl
  91. ;        Um Libr wie einen Linker funktionieren zu lassen ist die
  92. ;        Steuerung F aufgenommen worden. Diese Version eines Libr könnte
  93. ;        auch ohne Probleme z.B. in vc integriert werden. Da hätte nur
  94. ;        mal jemand früher drauf kommen müssen (meine erste Version war
  95. ;        ein List-Batch wie bei 7% noch zu sehen).
  96. ;        Y0 startet einen Stub-Batch der weitere Link-Libs erstellt, wenn
  97. ;        dies notwendig ist (siehe Verzeichnis Batch).
  98. ;        Bei PPC wird Y1 als Erweiterung von L= eingesetzt, so kommt der
  99. ;        Batch zur Ausführung und das .a-File für PPC wird gebildet. 
  100. ;
  101. :BEGIN DOSLIB
  102. PFAD=Proj:DOSLIB
  103. $5=-Ivinclude: -IInclude: -I$I
  104. 7%$5=-Ivincludeppc: -IInclude: -I$I
  105. 8%$5=-Ivincludewos: -IInclude: -I$I
  106. 1%$$=Lib:DOSLIB_000.Lib
  107. 2%$$=Lib:DOSLIB_010.Lib
  108. 3%$$=Lib:DOSLIB_020.Lib
  109. 4%$$=Lib:DOSLIB_030.Lib
  110. 5%$$=Lib:DOSLIB_040.Lib
  111. 6%$$=Lib:DOSLIB_060.Lib
  112. 7%$$=Lib:DOSLIB_ppc.a
  113. 8%$$=Lib:DOSLIB_wos.Lib
  114. $o=T:LibList
  115. 1%L=PmmLibr F Lib:DosLib_000 $o
  116. 2%L=PmmLibr F Lib:DosLib_010 $o
  117. 3%L=PmmLibr F Lib:DosLib_020 $o
  118. 4%L=PmmLibr F Lib:DosLib_030 $o
  119. 5%L=PmmLibr F Lib:DosLib_040 $o
  120. 6%L=PmmLibr F Lib:DosLib_060 $o
  121. 7%L=List Proj:DOSLIB/obj/ppc/#?.o lformat="ppc-amigaos-ar q Lib:DOSLIB_ppc.a %s%s" >Ram:LibList
  122. 8%L=PmmLibr F Lib:DosLib_wos $o
  123. 5%X5=Execute Pmm:Batch/ManProto.s Proj:DOSLIB Include:DOSLIB_protos.h
  124. Y0=Execute Pmm:Batch/MakeStubAll.s
  125. 7%Y1=Execute Ram:LibList
  126. :END
  127. ;
  128. ; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
  129. ;
  130. ; Als Demo habe ich das zum vbcc-Compiler gehörende Programm vc gewählt
  131. ; PFAD=    Wo liegen die Sourcen?
  132. ; $9=      Variable, wird in Pmm.Cfg eingefügt, vc muß mit -DAMIGA übersetzt werden
  133. ; $$=      Executable (hier gleich 8 unterschiedliche, aufgeteilt in eigene Verzeich-
  134. ;          nissse in denen auch die .o-Files gelagert werden). Mag etwas übertrieben
  135. ;          aussehen, aber bei 100 .c-Files kämen 800 .o-Files raus. Wer's nicht, oder
  136. ;          anders möchte kann sich das ja umstellen.
  137. ; $L       Link-Lib, Erweiterung zum Standard, hier auskommentiert, vc braucht meine
  138. ;          persönlichen Files nicht. Das muß auch jede Nutzer selber einrichten.
  139. ; $o       Obj-Liste für den Linker (Temp-File)
  140. ; X0       Aufruf Programmes VOR dem Make z.b. Versionsdumper
  141. ; Y0       Copy der 68040-Version ins vbcc-bin-Verzeichnis (zur Sicherheit aber
  142. ;          unter anderem Namen). Und, als Demo, 4 der maximal 8 Versionen werden
  143. ;          kopiert.
  144. ;
  145. :BEGIN vc
  146. PFAD=vbcc://frontend
  147. $9=-DAMIGA
  148. 1%$$=obj/000/vc
  149. 2%$$=obj/010/vc
  150. 3%$$=obj/020/vc
  151. 4%$$=obj/030/vc
  152. 5%$$=obj/040/vc
  153. 6%$$=obj/060/vc
  154. 7%$$=obj/ppc/vc.elf
  155. 8%$$=obj/wos/vc
  156. ;
  157. ;     Die folgenden Zeilen definieren .Lib's für den Linker.
  158. ;     Sie sind jetzt auskommentiert, da das eigene Lib's sind und vc
  159. ;     braucht sie definitiv nicht.
  160. ;
  161. ;$L=Lib:DOSLIB_000.Lib Lib:All.Lib
  162. ;5%$L=Lib:DOSLIB_040.Lib Lib:All_040.Lib
  163. ;6%$L=Lib:DOSLIB_060.Lib Lib:All_040.Lib
  164. ;7%$L=Lib:DOSLIB_ppc.a Lib:All_ppc.a
  165. ;8%$L=Lib:DOSLIB_wos.Lib Lib:All_wos.Lib
  166. $o=T:LinkVC
  167. 5%X0=Echo "Ich simuliere einen Versionsdumper, der aber nur bei 68040 anläuft."
  168. 1%Y0=Copy obj/000/vc vbcc://bin/vc_000
  169. 5%Y0=Copy obj/040/vc vbcc://bin/vc_040
  170. 7%Y0=Copy obj/ppc/vc.elf vbcc://bin/vc_ppc
  171. 8%Y0=Copy obj/040/vc vbcc://bin/vc_wos
  172. :END
  173.  
  174. ; :BEGIN xxx ist der Anfang einer Programmdefinition. Diese muß mit :END beendet
  175. ; werden. Der Name hinter BEGIN hat keine Bedeutung für's Compilat, er verbindet
  176. ; jedoch diese Definition mit den Dateien List_xxx und Work_xxx und ist auch der
  177. ; Parameter für Pmm 'Pmm -p xxx'. Der Programmname den der Compiler erzeugt ist
  178. ; in $$ festgelegt, ggf. auch mehrmals (siehe oben). BEGIN/END dürfen immer nur
  179. ; im Wechsel genau EINMAL benutzt werden. Alle anderen Zeilen können mit #%, also
  180. ; 0%, 1% ... 9% CPU-typisch gesetzt werden. An Y0 ist zu erkennen, wie eine
  181. ; Funktion nur bei einzelnen CPU's benutzt wird. $L zeigt eine Variante wo es
  182. ; einen Standard-Wert gibt, der in Einzelfällen verändert ist. $$ wiederum ist
  183. ; für alle CPU's einzeln festgelegt. PFAD ist die letzte Möglichkeit, nur eine
  184. ; Definition für alle ($9 und $o dito).
  185.